package leetcode.editor.cn;

import java.util.Arrays;

/**
  * 题目Id：443
  * 题目：压缩字符串
  * 日期：2023-04-26 18:40:17
*/
//给你一个字符数组 chars ，请使用下述算法压缩： 
//
// 从一个空字符串 s 开始。对于 chars 中的每组 连续重复字符 ： 
//
// 
// 如果这一组长度为 1 ，则将字符追加到 s 中。 
// 否则，需要向 s 追加字符，后跟这一组的长度。 
// 
//
// 压缩后得到的字符串 s 不应该直接返回 ，需要转储到字符数组 chars 中。需要注意的是，如果组长度为 10 或 10 以上，则在 chars 数组中会
//被拆分为多个字符。 
//
// 请在 修改完输入数组后 ，返回该数组的新长度。 
//
// 你必须设计并实现一个只使用常量额外空间的算法来解决此问题。 
//
// 
//
// 示例 1： 
//
// 
//输入：chars = ["a","a","b","b","c","c","c"]
//输出：返回 6 ，输入数组的前 6 个字符应该是：["a","2","b","2","c","3"]
//解释："aa" 被 "a2" 替代。"bb" 被 "b2" 替代。"ccc" 被 "c3" 替代。
// 
//
// 示例 2： 
//
// 
//输入：chars = ["a"]
//输出：返回 1 ，输入数组的前 1 个字符应该是：["a"]
//解释：唯一的组是“a”，它保持未压缩，因为它是一个字符。
// 
//
// 示例 3： 
//
// 
//输入：chars = ["a","b","b","b","b","b","b","b","b","b","b","b","b"]
//输出：返回 4 ，输入数组的前 4 个字符应该是：["a","b","1","2"]。
//解释：由于字符 "a" 不重复，所以不会被压缩。"bbbbbbbbbbbb" 被 “b12” 替代。
// 
//
// 
//
// 提示： 
//
// 
// 1 <= chars.length <= 2000 
// chars[i] 可以是小写英文字母、大写英文字母、数字或符号 
// 
//
// Related Topics 双指针 字符串 👍 343 👎 0


public class StringCompression {
    public static void main(String[] args) {
        Solution solution = new StringCompression().new Solution();
        int compress = solution.compress(new char[]{'a', 'a', 'b', 'b', 'c','c', 'c'});
        System.out.println(compress);

        System.out.println("Hello world");
    }
    //leetcode submit region begin(Prohibit modification and deletion)

    /**
     *
     */
    class Solution {
    public int compress(char[] chars) {

        //双指针
        int charsP=0;
        int num=0;
        StringBuffer buffer = new StringBuffer();
        while(charsP!=chars.length-1){
            num++;
            if(chars[charsP]!=chars[charsP+1]){
                //另一个写
                buffer.append(num);
                num=0;
            }
            if(num==1){
                buffer.append(chars[charsP]);
            }
            charsP++;
        }
        //判断最后一个
        if(chars[chars.length-1]==chars[chars.length-2]){
            buffer.append(++num);
        }else{
            buffer.append(chars[chars.length-1]+1);
        }
        System.out.println(Arrays.toString(buffer.toString().toCharArray()));
        return buffer.toString().toCharArray().length;
    }
}
//leetcode submit region end(Prohibit modification and deletion)

} 
